import { getTopcategoryAPI } from '@/apis/category'
import { onMounted, ref } from 'vue';
import { useRoute } from 'vue-router';
import { onBeforeRouteUpdate } from 'vue-router'


export function useCategory() {
  const categoryData = ref({})

  // 如何在setup中获取路由参数 useRoute() => route 等价于this.$route
  const route = useRoute()

  const getCategory = async (id = route.params.id) => {
    const res = await getTopcategoryAPI(id)
    categoryData.value = res.result
  }

  onMounted(() => getCategory())

  // 目标:路由参数变化的时候 可以把分类数据接口重新发送
  onBeforeRouteUpdate((to) => {
    // 存在问题：使用最新的路由参数请求最新的分类数据
    // console.log(to);
    getCategory(to.params.id)
  })

  return {
    categoryData
  }
}

